## In the Claims:

Claims 31-65 were allowed in the office action of Sept 11, 2002

5 Claims 1-30, 66-72 remain.

Claims 3, 10, 24, and 66 are amended.

## Clean Claims

- 10 1) A process for transmitting a packet having a header and variable length payload on a communications interface comprising the steps:
  - a first step of sending IDLE symbols until a synchronization time has passed;
- a second step of sending said packet including a START symbol and TYPE field identifying the format of said payload including an FCS sequence;
  - a third step of sending said variable length payload;
  - a fourth step of sending a terminator including an END symbol indicating end of transmission of said packet;
  - a fifth step of sending IDLE symbols if next said packet is not ready to transmit, or returning to said second step if said next packet is ready to transmit.

2) The process of claim 1 wherein said TYPE field uniquely identifies said payload format, said format including Ethernet packets, native IP packets, ATM cells, and control packets.

5

Sulp M

3) the process of claim 2 wherein said header includes declaration fields for at least one of BPDU, PRIORITY, VLAN\_ID, and an application specific field.

- 10 4) The process of claim 3 wherein said BPDU field is 1 bit in size.
  - 5) The process of claim 3 wherein said PRIORITY field is 3 bits in size.

15

- 6) The process of claim 3 wherein said VLAN\_ID field is 12 bits in size.
- 7) The process of claim 3 wherein said application 20 specific field is 32 bits in size.

8) The process of claim 3 wherein said header comprises, in sequence, said START symbol, said BPDU field, said TYPE field, said PRIORITY field, said VLAN\_ID field, and said application-specific field.

5

9) The process of claim 1 wherein a plurality n of data lanes carry said header, said payload, and said END symbol.

941) 19 16 10) the process of claim 9 wherein

said second step comprises transmitting said header across said n data lanes until all said header information has been sent;

 $\int_{0}^{T}$ 

said third step comprises transmitting said variable length payload, wherein during a final payload cycle, said payload ends on a data lane m;

for the case where m < n, said fourth step includes sending on said final payload cycle said END symbol on lane m+1, and said IDLE symbol on any available data lanes m+2 through n;

20

15

for the case where m=n, said fourth step comprises sending said END symbol on data lane 0, and said IDLE symbol on data lane 1 through said data lane n.

- 11) The process of claim 10 where n = 8.
- 12) The process of claim 10 where n = 4.
- 5 13) The process of claim 10 where n = 2.

said third step comprises transmitting said variable length payload on said data lane,

said fourth step comprises sending said END symbol on said data lane.

15

- 15) The process of claim 10 wherein at least one said data lane comprises a serial electrical link.
- 16) The process of claim 10 wherein at least one said
  20 data lane comprises a parallel electrical link.

- 17) The process of claim 10 wherein at least one said data lane comprises one or more serial or parallel optical links.
- 5 18) The process of claim 10 wherein said first step comprises the transmission of said IDLE symbols on all said n data lanes.
- 19) The process of claim 18 wherein said IDLE symbols
  10 are transmitted across all said n data lanes when there is
  no said packet data available to transmit.
- 20) The process of claim 19 wherein successive data lane cycles toggle successively between the states odd and even.
  - 21) The process of claim 20 wherein said IDLE symbols transmitted comprise IDLE\_ODD symbols during said odd state, and IDLE\_EVEN symbols during said even state.

20

3

22) A communication interface comprising n data lanes, said interface sequentially transmitting a header distributed across a plurality of said data lanes, a Amendment for: Multi-Function High Speed Network Interface by Bechtolsheim et al. s/n 09/339,963

variable amount of payload data distributed across a plurality of said n data lanes.

23) The communication interface of claim 22 wherein said transmission of said header includes transmitting a START symbol on first said data lane, and the transmission of said payload data is followed by an END symbol on at least one said data lane.

Sully 10

24) A communication interface comprising n data lanes, said interface sequentially transmitting a header distributed across a plurality of said data lanes, a variable amount of payload data distributed across a plurality of said n data lanes;

1

15

20

said header includes transmitting a START symbol on first said data lane, and the transmission of said payload data is followed by an END symbol on at least one said data lane;

said payload data includes transmitting data across said n data lanes up to data lane m, where m <= n.

25) The communication interface of claim 24 wherein if said m < n, said END symbol is transmitted on data lane m+1,

and if said m=n, said END symbol is transmitted on data lane 0.

- 26) The communication interface of claim 25 wherein
  5 each said data lane is identified by the alternating states
  of odd and even cycles.
  - 27) The communication interface of claim 26 wherein said IDLE symbol is IDLE\_EVEN during said even cycle and IDLE\_ODD during said odd cycle.
  - 28) The communication interface of claim 27 wherein all said data lane 0 through data lane n transmit IDLE\_EVEN during said even cycles, and IDLE\_ODD during said odd cycles.
  - 29) The communication interface of claim 28 where  $\label{eq:decomposition} \mbox{IDLE\_EVEN or IDLE\_ODD are transmitted after said END symbol at least once during every interval $t_{\rm elasticity}$.$

20

10

15

30) The communication interface of claim 29 where  $t_{elasticity} = T_{transmit} * clk_offset$ ,

where

 $T_{transmit}$  = time since last IDLE transmittal

clk\_offset = (maximum Transmit clock rate - minimum
receive clock rate) / (minimum receive clock rate).

- 31) A transmit processor comprising:
- 5 a busy input;

10

15

20

a transmit buffer/controller accepting packet data comprising a header and a payload as input, arranging said packet data into a plurality n of data lanes, and delivering to each said data lane unencoded transmit data and a control signal, whereby when said control signal is asserted, said unencoded transmit data includes at least one of the values START, END, IDLE\_BUSY and when said control signal is not asserted, said transmit data includes said packet data;

a plurality n of transmit encoders, each having an input and an output, each of said transmit encoder inputs uniquely coupled to one of said transmit buffer/controller data lanes, said transmit encoder input comprising said unencoded transmit data and said control signal, said transmit encoder output producing a unique encoded output value for each said unencoded transmit data value when said control signal is not asserted, and producing a unique encoded output values for each unencoded transmit data

START, END, IDLE, and IDLE\_BUSY when said control signal is asserted;

a plurality n of transmit serializers, each having an input uniquely coupled to one of said transmit encoder outputs, said transmit serializers outputting a single serial stream of data from said transmit serializer input;

wherein said transmit buffer/controller sends said header by outputting on said first data lane the asserted said control and said unencoded transmit data START, and simultaneously outputs the remainder of said header on said remaining data lanes accompanied by said unasserted control signal for each said data lane,

thereafter and on each successive cycle said transmit buffer/controller distributes said payload data on all said data lanes and sends it to said transmit encoder with said unasserted control signal accompanied by said payload data, until unsent said payload data can not fully span said n data lanes,

thereafter said transmit buffer/controller sends the last said payload data on each said data lane with associated said control signal unasserted, with following said data lane having said control signal asserted accompanied by said unencoded data END, and the remaining said data lanes having said control signal asserted accompanied by said unencoded data IDLE.

Amendment for: Multi-Function High Speed Network Interface by Bechtolsheim et al. s/n 09/339,963

5

10

15

32) The transmit processor of claim 31 wherein each said transmit cycle has the state odd or even, and said IDLE comprises an IDLE\_EVEN sent on said even cycles or an IDLE\_ODD sent on said odd cycle.

5

33) The transmit processor of claim 32 wherein each successive transmit cycle alternates between odd or even, said IDLE\_EVEN is sent during even cycles, and IDLE\_ODD is sent during odd cycles.

10

34) The transmit processor of claim 32 wherein said IDLE comprises an IDLE when said busy input is not asserted, or a IDLE\_BUSY when said busy input is asserted.

15

20

- 35) The transmit processor of claim 34 wherein said IDLE comprises an IDLE\_EVEN\_BUSY during said even cycle when said busy input is asserted, an IDLE\_EVEN during said even cycle when said busy input is not asserted, an IDLE\_ODD\_BUSY during said odd cycle when said busy input is asserted, and an IDLE\_ODD during said odd cycle when said busy is not asserted.
- 36) The transmit processor of claim 35 wherein said transmit encoder comprises an 8B/10B encoder.

- 37) The transmit processor of claim 36 wherein the number of said data lanes n = 8.
- 38) The transmit processor of claim 36 wherein the number of said data lanes n = 4.
  - 39) The transmit processor of claim 36 wherein the number of said data lanes n = 2.
- 10 40) The transmit processor of claim 36 wherein the number of said data lanes n = 1.
  - 41) The transmit processor of claim 36 wherein the 10B coding value for symbol START is K27.7.
  - 42) The transmit processor of claim 36 wherein the 10B coding value for symbol END is K29.7.
- 43) The transmit processor of claim 36 wherein the 10B coding value for symbol IDLE\_EVEN is K28.5.
  - 44) The transmit processor of claim 36 wherein the 10B coding value for symbol IDLE\_ODD is K23.7.

Amendment for: Multi-Function High Speed Network Interface by Bechtolsheim et al. s/n 09/339,963

- 45) The transmit processor of claim 36 wherein the 10B coding value for symbol IDLE\_EVEN\_BUSY is K28.1.
- 46) The transmit processor of claim 36 wherein the 10B coding value for symbol IDLE\_ODD\_BUSY is K28.0.
  - 47) The transmit processor of claim 36 wherein the 10B coding values for the symbols START, END, IDLE\_EVEN, IDLE\_EVEN\_BUSY, IDLE\_ODD, and IDLE\_ODD\_BUSY have unique values when compared to any coded 10B data value.
- 48) The transmit processor of claim 47 wherein the 10B coding values for the symbols START, END, IDLE\_EVEN, IDLE\_EVEN\_BUSY, IDLE\_ODD, and IDLE\_ODD\_BUSY are separated by hamming distance 2.
  - 49) A receive processor comprising:

a plurality n of receive descrializers each accepting as input a serial stream of encoded data and outputting descrialized encoded data;

a plurality n of receive decoders each uniquely coupled to and accepting as input said deserialized encoded data and providing as output decoded data and decoded control signals, said decoded data including at least on of the

Amendment for: Multi-Function High Speed Network Interface by Bechtolsheim et al. s/n 09/339,963

10

values START, END, and IDLE when said control signal is asserted;

5

10

15

20

25

a receive buffer/controller for the formation of data packets, said buffer/controller having a plurality n of inputs, each uniquely coupled to said decoded data and said decoded control, said buffer/controller having a busy output and a data output, said receive buffer/controller awaiting START on said first lane with associated control signal asserted, and storing a header on the remaining said data lanes when said START is received, and transferring to said data output all subsequent data while said control signal is unasserted for all said data lanes, and upon receipt of said END accompanied by the assertion of said associated control signal on any data lane, transferring said decoded data to said data output all said received data up to but not including said data lane having said control signal END.

- 50) The receive processor of claim 49 wherein said IDLE comprises the symbols IDLE\_EVEN, IDLE\_ODD, IDLE\_EVEN\_BUSY, and IDLE\_EVEN\_ODD.
- 51) The receive processor of claim 50 including a busy signal wherein the reception of IDLE\_EVEN\_BUSY or IDLE\_ODD\_BUSY causes said receive processor to assert said busy output.

Amendment for: Multi-Function High Speed Network Interface by Bechtolsheim et al. s/n 09/339,963 Last saved 12/11/2002 2:53 PM

52) The receive processor of claim 49 wherein said receive decoder uses a 10B/8B decoding method for converting said encoded data into said decoded data.

5

53) The receive processor of claim 52 wherein each receive deserializer achieves synchronization using the symbols IDLE\_EVEN and IDLE ODD.

10

54) the receive processor of claim 52 wherein the 10B coding value for symbol START is K27.7.

15

- 55) The receive processor of claim 52 wherein the 10B coding value for symbol END is K29.7.
- 56) The receive processor of claim 52 wherein the 10B coding value for symbol IDLE\_EVEN is K28.5.
- 57) The receive processor of claim 52 wherein the 10B 20 coding value for symbol IDLE\_ODD is K23.7.
  - 58) The receive processor of claim 52 wherein the 10B coding value for symbol IDLE\_EVEN\_BUSY is K28.1.

- 59) The receive processor of claim 52 wherein the 10B coding value for symbol IDLE\_ODD\_BUSY is K28.0.
- 5 60) The receive processor of claim 52 wherein the 10B encoded values for the symbols START, END, IDLE\_EVEN and IDLE\_ODD have unique values when compared to any other encoded 10B data value.
- 10 61) The receive processor of claim 60 wherein the 10B coding values for the symbols START, END, IDLE\_EVEN, and IDLE\_ODD are separated by hamming distance 2.
- 62) The receive processor of claim 49 wherein the 15 number of data lanes n = 8.
  - 63) The receive processor of claim 49 wherein the number of data lanes n = 4.
- 20 64) The receive processor of claim 49 wherein the number of data lanes n = 2.
  - 65) The receive processor of claim 49 wherein the number of data lanes n = 1.

25

Supp'

66) A communications interface for sending or receiving a packet, said packet comprising, in sequence, a header, variable length payload, and a terminator;

A

said header including a START symbol and a TYPE field identifying the format of said payload;

said terminator including an END symbol;
wherein said START symbol is transmitted first,
followed by the remainder of said header, followed by said
variable length packet payload, followed by said terminator.

10

5

- 67) The interface of claim 66 wherein said TYPE field uniquely identifies said payload format, said format including Ethernet packets, ATM cells, and control packets.
- 15 68) the interface of claim 67 wherein said header [further] includes declaration fields for at least one of BPDU, PRIORITY, VLAN\_ID, and an application specific field.
- 69) The interface of claim 68 wherein said BPDU field 20 is 1 bit in size.
  - 70) The interface of claim 69 wherein said PRIORITY field is 3 bits in size.

- 71) The interface of claim 70 wherein said VLAN\_ID field is 12 bits in size.
- 5 72) The interface of claim 71 wherein said application specific field is 32 bits in size.